package org.dromara.finance.service;

import org.dromara.finance.domain.vo.StaffVo;
import org.dromara.finance.domain.bo.StaffBo;
import org.dromara.common.mybatis.core.page.TableDataInfo;
import org.dromara.common.mybatis.core.page.PageQuery;

import java.util.Collection;
import java.util.List;

/**
 * 员工Service接口
 *
 * @author xxy
 * @date 2025-08-15
 */
public interface IStaffService {

    /**
     * 查询员工
     *
     * @param id 主键
     * @return 员工
     */
    StaffVo queryById(Long id);

    /**
     * 分页查询员工列表
     *
     * @param bo        查询条件
     * @param pageQuery 分页参数
     * @return 员工分页列表
     */
    TableDataInfo<StaffVo> queryPageList(StaffBo bo, PageQuery pageQuery);

    /**
     * 查询符合条件的员工列表
     *
     * @param bo 查询条件
     * @return 员工列表
     */
    List<StaffVo> queryList(StaffBo bo);

    /**
     * 新增员工
     *
     * @param bo 员工
     * @return 是否新增成功
     */
    Boolean insertByBo(StaffBo bo);

    /**
     * 修改员工
     *
     * @param bo 员工
     * @return 是否修改成功
     */
    Boolean updateByBo(StaffBo bo);

    /**
     * 校验并批量删除员工信息
     *
     * @param ids     待删除的主键集合
     * @param isValid 是否进行有效性校验
     * @return 是否删除成功
     */
    Boolean deleteWithValidByIds(Collection<Long> ids, Boolean isValid);
}
